<?php
/**
 * @title 5526. 最多可达成的换楼请求数目 - 统计
 * @author start2004
 */

// ini_set("memory_limit", "128M");

// class Solution {
//
//     function find() {
//
//     }
// }


class Solution {

    /**
     * @param Integer $n
     * @param Integer[][] $requests
     * @return Integer
     */
    function maximumRequests($n, $requests) {
        /**
         * @since 2020-09-27 初始化每个楼净出人数
         */
        $nums = array_fill(0, $n, 0);

        /**
         * @since 2020-09-27 每个人进出
         */
        foreach ($requests as list($out, $in)){
            $nums[$out] -= 1;
            $nums[$in] += 1;
        }
        // return $nums;

        /**
         * @since 2020-09-27 进出不平衡, 即不满足换楼请求
         */
        $sum = 0;
        foreach ($nums as $num){
            $sum += abs($num);
        }

        /**
         * @since 2020-09-27 总人数
         */
        $total = count($requests);
        // return [$total, $sum];
        $result = $total - ($sum>>1);

        /**
         * @return
         */
        return $result;
    }
}

/**
 * @url http://127.0.0.1/leetcode/202009/2020.09.27_8.php
 */
$datas = [
    // [5, [[0,1],[1,0],[0,1],[1,2],[2,0],[3,4]]],
    // [3, [[0,0],[1,2],[2,1]]],
    // [4, [[0,3],[3,1],[1,2],[2,0]]],
    [3, [[0,0],[1,1],[0,0],[2,0],[2,2],[1,1],[2,1],[0,1],[0,1]]], // 5
];

include_once dirname(__DIR__) . DIRECTORY_SEPARATOR ."xhprof.php";
$xhprof = new Xhprof();
foreach ($datas as $data){
    var_dump($data);

    $obj = new Solution();
    $result = $obj->maximumRequests(...$data);
    // $result = $obj->($xhprof->tree($data));
    // $result = $obj->find(...$data);
    var_dump($result);
    // if(count($result)<=20){
    //     var_dump($result);
    // } else {
    //     var_dump(count($result));
    // }
    echo str_repeat("<br>", 3);
}

// foreach ($datas as $data){
//     $obj = new $data[0][0](...$data[1][0]);
//
//     for ($i=1; $i<count($data[0]); $i++){
//         $result = $obj->$data[0][$i](...$data[1][$i]);
//
//         echo $data[0][$i] ."(\"". implode(",", $data[1][$i]) ."\") ";
//             if($result === true){
//                 echo "True";
//             } elseif($result === false) {
//                 echo "False";
//             } elseif($result === null) {
//                 echo "Null";
//             } elseif(is_array($result)) {
//                 var_dump($result);
//             } else {
//                 echo $result;
//             }
//         echo PHP_EOL;
//     }
//
//     echo str_repeat(PHP_EOL, 3);
// }
$xhprof->end();
